EE/CprE/Se 492 Weekly Report 3 2/14/25 - 2/27/25 sdmay25-28 Digital ASIC fabrication Client & Advisor: Dr. Duwe

### **Team Members**

Calvin Smith – Accelerator Design lead
Camden Fergen – DevOps and Project Lead
John – Testing Lead
Nicholas – Harden and Verification lead
Levi – Communication Interfaces Lead

## Weekly Summary

These past two weeks we have been able to get a good basis to our CyGRA, we were able to perform a MAC operation in 2 cycles and simply utilizing the memory that was in the CyGRA. Additionally we have started to get some testing setup on an FPGA to ensure our components work both in simulation and hardware.

### Pask Week Accomplishments

### Calvin:

- o Worked on getting the caravel project running on the FPGA with Camden and John
- o Made a memory interface bus priority splitter for when we need a second memory interface when we implement the DMA into the CyGRA
- o Finished the CyGRA v1.0

#### Camden:

- o Started to try and get the caravel on the FPGA to enable testing
- o Found repository that is supported by efabless that enables this, but was unable to get it to generate the bitstream, some errors that need to be fixed or reviewed

#### • John:

- o I was able to work on updating the previous version of the CyGRA, created a decoder and processing element array to split the functionality of the CyGRA into its own modules for ease of use.
- Was able to create some simple test benches to test the decoder and was able to perform a MAC operation using our CyGRA

o Working with Nick we were able to generate a bitstream with SPI I/O to communicate with the PMOD and off-chip memory

## Levi:

- o Last update (missed last report) worked on selecting base IP for SPI Master unit and commenting out code and implementing testbench on said IP, did not get to implementing interactions with the memory controller
- o Current update: Worked on getting benchmarks from embench to run on the picorv32 processor implemented on the Zynq FPGAs via Vitis in 2041 Coover.

# Nicholas:

- o Integrated the Pico, Memory Controoler, WBS, cache, and memory into a caravel wrapper for RTL testing
- o Worked on a Vivado project containing non-CyGRA components

| Name   | Individual                                                                                                                                                                                                                         | Hours this Week       | Hours Cumulative |
|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|------------------|
|        | Contribution                                                                                                                                                                                                                       |                       |                  |
| Calvin | <ul><li>CyGRA v1.0</li><li>Memory splitter</li><li>Moral Support</li></ul>                                                                                                                                                         | 10                    | 100.044          |
| Camden | <ul> <li>Found efabless repo for testing on fpga</li> <li>Started working on project in vivado and following the provided documentation</li> <li>Helped generate bitstream for separate FPGA testing outside of caravel</li> </ul> | 8                     | 80               |
| John   | <ul> <li>CyGRA v1.1         <ul> <li>Decoder</li> <li>PE Array</li> </ul> </li> <li>Generated         <ul> <li>bitstream to</li> <li>communicate</li> <li>with off chip</li> <li>memory</li> </ul> </li> </ul>                     | 12                    | 100              |
| Levi   | Last update: SPI master unit                                                                                                                                                                                                       | Last: 8<br>Current: 6 | 82               |

|          | Current update:<br>embench testing<br>on FPGA of<br>picorv32<br>processor as a<br>baseline                                                                                       |    |     |
|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|-----|
| Nicholas | <ul> <li>Integrated design into Caravel Wrapper</li> <li>Wrote tests for design</li> <li>Working on getting CyGRAless design working on an FPGA to perform benchmarks</li> </ul> | 10 | 106 |

## Plans for Upcoming Week

### Calvin:

- o Finish the CyDMA v1.0
- o Get it incorporated into the fpga testing flow

### Camden:

- o Continue trying to get the FPGA testing to work based on the efabless documentation and repo
- o Look into the tooling that Gregory ling created that is supposed to create a vivado project with caravel (wasn't able to get to work so far)

### John:

- o Work on updating the CyGRA based on our benchmarks
- o Work on being able to load off-chip memory

### • Levi:

- Work with Nicholas for system level testing between the SPI Master and memory controller
- Scope out more benchmarks and run baseline tests on the FPGA picorv32
   implementation and select metrics for comparison

### Nicholas:

- o Continue working on getting FPGA simulations of the base user project and the project inside the caravel wrapper working.
- o Create a unit to interface the SPI Master with the memory controller.

# Summary of weekly advisor meeting

Professor Duwe was happy to see our progress, suggested that before we continue working on the CyGRA we find some benchmarks so that we know what accelerations we need to accelerate. We also need to learn how we are going to load off chip memory, he suggested using the memory PMOD that was developed by Chip Forge. He also suggested having a good portion of our project hardened so that we are able to speed up the final process with getting it onto the chip with the other projects.